// This file is part of OpenTSDB.
// Copyright (C) 2017 TeleDB Development Group.
//
// This program is free software: you can redistribute it and/or modify it
// under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation, either version 2.1 of the License, or (at your
// option) any later version.  This program is distributed in the hope that it
// will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty
// of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser
// General Public License for more details.  You should have received a copy
// of the GNU Lesser General Public License along with this program.  If not,
// see <http://www.gnu.org/licenses/>.
package net.opentsdb.utils.hbase;

import net.opentsdb.core.TSDB;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * 每张hbase表操作有差异，在此封装不同操作
 *  TODO 工厂模式实现了创建操作类，应不需要这个类的，后续优化
 */
public class HbaseWrapper {
    private static final Logger LOG = LoggerFactory.getLogger(HbaseWrapper.class);

    private final TSDB tsdb;
    public final HbaseMetaUtils metaUtils;
    public final HbaseTagUtils tagUtils;
    public final HbaseTsdbUtils tsdbUtils;

    public HbaseWrapper(TSDB tsdb){
        this.tsdb = tsdb;
        metaUtils = (HbaseMetaUtils)HbaseFactory.createHbaseUtils(tsdb, tsdb.metaTable());
        tagUtils = (HbaseTagUtils)HbaseFactory.createHbaseUtils(tsdb, tsdb.tagTable());
        tsdbUtils = (HbaseTsdbUtils)HbaseFactory.createHbaseUtils(tsdb, tsdb.dataTable());
    }
}
